Activity 生命周期,如何一手掌控
版权声明:
本公众号发布的所有文章,均属于原创,版权归本公众号所有。
未经允许,不得转载。
一、前言
对于一个 Activity 而言,它是有固定的生命周期的,但是它只是对于 Activity 自身的一种管理。如果有需求需要对 App 内,所有 Activity 的生命周期进行管理的话,就需要另行处理了。
这个时候,就可以用到 Android level 14 (Android 4.0) 新添加的 API ,AndroidLifecycleCallbacks 就可以对当前进程内所有的 Activity 进行统一的管理了。
二、什么是AndroidLifecycleCallback
AndroidLifecycleCallback 是 Android 4.0 新添加的API ,它是一个 Application 内的公有接口。而使用它,也需要配合 Application 对象进行使用。
既然 AndroidLifecycleCallbacks 是全局的管理 Activity 的生命周期,它自然需要对应出 Activity 的所有生命周期的方法。
可以看到,这里的 AndroidLifecycleCallback 是一个接口,我们需要实现它。并通过 registerActivityLifecycleCallbacks()
方法,将其注册到当前的 Application 对象上,在无需使用的时候,还需要调用 unregisterActivityLifecycleCallbacks()
进行解注。
从注册和解注的方法实现中就可以看出来,它实际上就是通过一个 ArrayList 的数组,mActivityLifecycleCallbacks 进行维护的,也就是说,我们可以在 Application 对象上添加多个 Callbacks 监听。
而具体是何时使用它的,就是完全依赖于 Application 的一些方法了,就以 Activity.onCreate()
的监听为例子。
这里就是将 Callbacks 拿出来,循环调用对应的方法即可。
三、适用场景比如何使用更重要
其实 AndroidLifecycleCallback 的 API 非常的简单,使用起来也并不复杂,所以说,在什么场景下使用它,比如何使用它更重要。
常见的一些使用场景:
1、为页面添加统计
如果需要为每个页面,添加页面的PV、UV等统计的话,除了在每个 Activity 的对应声明周期方法内,添加统计之外,就可以用到 AndroidLifecycleCallbacks 进行统一添加,便于管理。
2、一键退出所有页面
既然可以对所有的 Activity 进行管理,当然可以做到一键退出所有 Activity 的功能。
3、判断当前App是否在前台
对于退出到后台的 App ,一定有一个 Activity 走到了 onPause() 而几乎同时没有另外一个 Activity 走到了 onResume()。最简单的一个实现方式,就是在 onActivityPaused() 的时候,使用 Handler 做一个延迟判断,如果马上就有另外一个 Activity 走到了 onActivityResume() 的时候,就将延迟消息 remove 掉,否者认为是退出到后台了。
四、LifecycleCallback 有什么缺陷
其实 ActivityLifecycleCallbacks 整体来说,还是很方便实用的。但是它也有一些缺陷的地方,例如有 Api 限制、无法监听到 Fragment 的生命周期等。
这里简单提一下对于这些问题的一个简单的解决方案,例子就不摆出来了。
既然需要兼容 Android 4.0 以下的设备,而这又仅仅是用于监听 Activity 的声明周期,实际上我们是可以用一个 Activity 的父类,让所有项目内的 Activity 都继承于它,这样的话,在这个父类中对应的声明周期方法内,去分发对应的监听回调即可。而 Fragment 生命周期的监听,思路也是如此的。
这一切如果实现起来觉得有点繁琐,可以参见一个开源项目:
https://github.com/soarcn/AndroidLifecyle
实际上它的思路和上面提到的思路是一样的,只是封装的更方便使用了,有需要的可以阅读一下源码就清楚了。
五、小结
能监听所有 Activity 的状态,是一件非常有意义的事情,它能实现哪些功能,就需要根据实际的需求和发挥我们的想象力了。
推荐阅读: